## **CECS 225: MUX TREE LAB**

OBJECTIVE: Create a 4 to 1 mux using multiple 2 to 1 multiplexers

PROCEDURE: In a new project space on EDA playground, create a new source file named mux2to1.v



Create a module skeleton for your mux 2 to 1 using the exact same module name, input variables, and output variable as shown in the image below.



Use image below to complete the module skeleton and make a 2 to 1 multiplexer.



## **CECS 225: MUX TREE LAB**

The design.sv file will contain what is known as your top level module. In hierarchical design, the module that connects together all other modules will be known as the top level module.

Create a top level module which interconnects multiple instances of the mux2to1 according to the block diagram below:



Use the following module skeleton to get started:

Pass variables into the port list parameter positions where the order of parameters must match the definition of the mux2to1 module.

Once you have modeled the circuit, its proper functionality can be verified using the tester on the following page.

## **CECS 225: MUX TREE LAB**

SV/Verilog Testbe 1 module mux4to1tester; reg d3,d2,d1,d0,s1,s0; wire y; 3 4 5 mux4to1 dut(d3,d2,d1,d0,s1,s0,y); integer i; 6 initial begin 7 8 \$display("Mux 4 to 1 tester!"); d0 = 1'b1; d1 = 1'b0; d2 = 1'bx; d3 = 1'b1; 9 10 \$display("\tTest case\td3\td2\td1\td0\t|\ts1\ts0\t|\ty"); 11 for (i = 0; i < 4; i = i + 1)12 13 begin {s1,s0}=i; 14 #1 \$display("%d\t\t%b\t%b\t%b\t|\t%b\t|\t%b",i,d3,d2,d1,d0,s1,s0,y); 15 16 \$finish; 17 end 18 19 endmodule

Correct test results will appear as follows:

| [2017-09 | 9-26 00:51:39 | EDT] | iverilog | '-Wall' | design.sv | testben | ch.sv | && unbuffe | r vvp a | a.out |
|----------|---------------|------|----------|---------|-----------|---------|-------|------------|---------|-------|
| Mux 4 to | 1 tester!     |      |          |         |           |         |       |            |         |       |
|          | Test case     | d3   | d2       | d1      | d0        |         | s1    | s0         | 1       | У     |
|          | 0             | 1    | x        | 0       | 1         |         | 0     | 0          | 1       | 1     |
|          | 1             | 1    | x        | 0       | 1         |         | 0     | 1          | 1       | 0     |
|          | 2             | 1    | x        | 0       | 1         |         | 1     | 0          | 1       | ×     |
|          | 3             | 1    | x        | 0       | 1         |         | 1     | 1          | 1       | 1     |
| Done     |               |      |          |         |           |         |       |            |         |       |

**WHAT TO TURN IN:** Once your mux4to1 module is completed and proper test results are produced:

- Copy the contents of your mux4to1 module to a file named mux4to1.txt
- Upload mux4to1.txt to the beachboard dropbox for mux4to1\_lab